
<!DOCTYPE HTML>
<html lang="" >
    <head>
        <meta charset="UTF-8">
        <meta content="text/html; charset=utf-8" http-equiv="Content-Type">
        <title>leveldb源码分析14 · 高性能服务器开发 技术专栏</title>
        <meta http-equiv="X-UA-Compatible" content="IE=edge" />
        <meta name="description" content="">
        <meta name="generator" content="GitBook 3.2.3">
        <meta name="author" content="easy_coder">
        
        
    
    <link rel="stylesheet" href="../../gitbook/style.css">

    
            
                
                <link rel="stylesheet" href="../../gitbook/gitbook-plugin-chapter-fold/chapter-fold.css">
                
            
                
                <link rel="stylesheet" href="../../gitbook/gitbook-plugin-search-pro/search.css">
                
            
                
                <link rel="stylesheet" href="../../gitbook/gitbook-plugin-splitter/splitter.css">
                
            
                
                <link rel="stylesheet" href="../../gitbook/gitbook-plugin-back-to-top-button/plugin.css">
                
            
                
                <link rel="stylesheet" href="../../gitbook/gitbook-plugin-prism/prism.css">
                
            
                
                <link rel="stylesheet" href="../../gitbook/gitbook-plugin-tbfed-pagefooter/footer.css">
                
            
                
                <link rel="stylesheet" href="../../gitbook/gitbook-plugin-code/plugin.css">
                
            
                
                <link rel="stylesheet" href="../../gitbook/gitbook-plugin-anchor-navigation-ex/style/plugin.css">
                
            
                
                <link rel="stylesheet" href="../../gitbook/gitbook-plugin-fontsettings/website.css">
                
            
                
                <link rel="stylesheet" href="../../gitbook/gitbook-plugin-theme-fexa/fexa.css">
                
            
        

    

    
        
    
        
    
        
    
        
    
        
    
        
    

        
    
    
    <meta name="HandheldFriendly" content="true"/>
    <meta name="viewport" content="width=device-width, initial-scale=1, user-scalable=no">
    <meta name="apple-mobile-web-app-capable" content="yes">
    <meta name="apple-mobile-web-app-status-bar-style" content="black">
    <link rel="apple-touch-icon-precomposed" sizes="152x152" href="../../gitbook/images/apple-touch-icon-precomposed-152.png">
    <link rel="shortcut icon" href="../../gitbook/images/favicon.ico" type="image/x-icon">

    
    <link rel="next" href="leveldb源码分析15.html" />
    
    
    <link rel="prev" href="leveldb源码分析13.html" />
    

    </head>
    <body>
        
<div class="book">
	<div class="header-inner">
		<!-- LOGO -->
		<div class="logo"></div>
		<span class="title"></span>

		<!-- Search -->
		
<div id="book-search-input" role="search">
    <input type="text" placeholder="Type to search" />
</div>


		<!-- Nav -->
		<ul class="header-nav">
			
		</ul>
	</div>

	<div class="book-summary">
		<div class="book-summary-title">文档目录</div>
		
		
		<nav role="navigation">
			


<ul class="summary">
    
    

    

    
        
        <li class="header">Part I</li>
        
        
    
        <li class="chapter " data-level="1.1" data-path="../../">
            
                <a href="../../">
            
                    
                    Introduction
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="1.2" data-path="../C++必知必会的知识点/">
            
                <a href="../C++必知必会的知识点/">
            
                    
                    C++必知必会的知识点
            
                </a>
            

            
            <ul class="articles">
                
    
        <li class="chapter " data-level="1.2.1" data-path="../C++必知必会的知识点/如何成为一名合格的CC++开发者？.html">
            
                <a href="../C++必知必会的知识点/如何成为一名合格的CC++开发者？.html">
            
                    
                    如何成为一名合格的C/C++开发者？
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="1.2.2" data-path="../C++必知必会的知识点/不定参数函数实现var_arg系列的宏.html">
            
                <a href="../C++必知必会的知识点/不定参数函数实现var_arg系列的宏.html">
            
                    
                    不定参数函数实现var_arg系列的宏
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="1.2.3" data-path="../C++必知必会的知识点/你一定要搞明白的C函数调用方式与栈原理.html">
            
                <a href="../C++必知必会的知识点/你一定要搞明白的C函数调用方式与栈原理.html">
            
                    
                    你一定要搞明白的C函数调用方式与栈原理
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="1.2.4" data-path="../C++必知必会的知识点/深入理解CC++中的指针.html">
            
                <a href="../C++必知必会的知识点/深入理解CC++中的指针.html">
            
                    
                    深入理解C/C++中的指针
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="1.2.5" data-path="../C++必知必会的知识点/详解C++11中的智能指针.html">
            
                <a href="../C++必知必会的知识点/详解C++11中的智能指针.html">
            
                    
                    详解C++11中的智能指针
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="1.2.6" data-path="../C++必知必会的知识点/C++17结构化绑定.html">
            
                <a href="../C++必知必会的知识点/C++17结构化绑定.html">
            
                    
                    C++17结构化绑定
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="1.2.7" data-path="../C++必知必会的知识点/C++必须掌握的pimpl惯用法.html">
            
                <a href="../C++必知必会的知识点/C++必须掌握的pimpl惯用法.html">
            
                    
                    C++必须掌握的pimpl惯用法
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="1.2.8" data-path="../C++必知必会的知识点/用VisualStudio调试Linux程序.html">
            
                <a href="../C++必知必会的知识点/用VisualStudio调试Linux程序.html">
            
                    
                    用Visual Studio调试Linux程序
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="1.2.9" data-path="../C++必知必会的知识点/如何使用VisualStudio管理和阅读开源项目代码.html">
            
                <a href="../C++必知必会的知识点/如何使用VisualStudio管理和阅读开源项目代码.html">
            
                    
                    如何使用Visual Studio管理和阅读开源项目代码
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="1.2.10" data-path="../C++必知必会的知识点/利用cmake工具生成VisualStudio工程文件.html">
            
                <a href="../C++必知必会的知识点/利用cmake工具生成VisualStudio工程文件.html">
            
                    
                    利用cmake工具生成Visual Studio工程文件
            
                </a>
            

            
        </li>
    

            </ul>
            
        </li>
    
        <li class="chapter " data-level="1.3" data-path="../多线程/">
            
                <a href="../多线程/">
            
                    
                    多线程
            
                </a>
            

            
            <ul class="articles">
                
    
        <li class="chapter " data-level="1.3.1" data-path="../多线程/后台C++开发你一定要知道的条件变量.html">
            
                <a href="../多线程/后台C++开发你一定要知道的条件变量.html">
            
                    
                    后台C++开发你一定要知道的条件变量
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="1.3.2" data-path="../多线程/整型变量赋值是原子操作吗？.html">
            
                <a href="../多线程/整型变量赋值是原子操作吗？.html">
            
                    
                    整型变量赋值是原子操作吗？
            
                </a>
            

            
        </li>
    

            </ul>
            
        </li>
    

    
        
        <li class="divider"></li>
        
        
    
        <li class="chapter " data-level="2.1" data-path="../网络编程/">
            
                <a href="../网络编程/">
            
                    
                    网络编程
            
                </a>
            

            
            <ul class="articles">
                
    
        <li class="chapter " data-level="2.1.1" data-path="../网络编程/bind函数重难点解析.html">
            
                <a href="../网络编程/bind函数重难点解析.html">
            
                    
                    bind 函数重难点解析
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="2.1.2" data-path="../网络编程/connect函数在阻塞和非阻塞模式下的行为.html">
            
                <a href="../网络编程/connect函数在阻塞和非阻塞模式下的行为.html">
            
                    
                    connect 函数在阻塞和非阻塞模式下的行为
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="2.1.3" data-path="../网络编程/select函数重难点解析.html">
            
                <a href="../网络编程/select函数重难点解析.html">
            
                    
                    select 函数重难点解析
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="2.1.4" data-path="../网络编程/Linuxepoll模型（含LT模式和ET模式详解）.html">
            
                <a href="../网络编程/Linuxepoll模型（含LT模式和ET模式详解）.html">
            
                    
                    Linux epoll 模型（含LT 模式和 ET 模式详解）
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="2.1.5" data-path="../网络编程/socket的阻塞模式和非阻塞模式.html">
            
                <a href="../网络编程/socket的阻塞模式和非阻塞模式.html">
            
                    
                    socket 的阻塞模式和非阻塞模式
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="2.1.6" data-path="../网络编程/非阻塞模式下send和recv函数的返回值.html">
            
                <a href="../网络编程/非阻塞模式下send和recv函数的返回值.html">
            
                    
                    非阻塞模式下 send 和 recv 函数的返回值
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="2.1.7" data-path="../网络编程/服务器开发通信协议设计介绍.html">
            
                <a href="../网络编程/服务器开发通信协议设计介绍.html">
            
                    
                    服务器开发通信协议设计介绍
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="2.1.8" data-path="../网络编程/TCP协议如何解决粘包、半包问题.html">
            
                <a href="../网络编程/TCP协议如何解决粘包、半包问题.html">
            
                    
                    TCP 协议如何解决粘包、半包问题
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="2.1.9" data-path="../网络编程/网络通信中收发数据的正确姿势.html">
            
                <a href="../网络编程/网络通信中收发数据的正确姿势.html">
            
                    
                    网络通信中收发数据的正确姿势
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="2.1.10" data-path="../网络编程/服务器端发数据时，如果对端一直不收，怎么办？.html">
            
                <a href="../网络编程/服务器端发数据时，如果对端一直不收，怎么办？.html">
            
                    
                    服务器端发数据时，如果对端一直不收，怎么办？
            
                </a>
            

            
        </li>
    

            </ul>
            
        </li>
    

    
        
        <li class="divider"></li>
        
        
    
        <li class="chapter " data-level="3.1" data-path="../程序员必知必会的网络命令/">
            
                <a href="../程序员必知必会的网络命令/">
            
                    
                    程序员必知必会的网络命令
            
                </a>
            

            
            <ul class="articles">
                
    
        <li class="chapter " data-level="3.1.1" data-path="../程序员必知必会的网络命令/利用telnet命令发电子邮件.html">
            
                <a href="../程序员必知必会的网络命令/利用telnet命令发电子邮件.html">
            
                    
                    利用telnet命令发电子邮件
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="3.1.2" data-path="../程序员必知必会的网络命令/做Java或者C++开发都应该知道的lsof命令.html">
            
                <a href="../程序员必知必会的网络命令/做Java或者C++开发都应该知道的lsof命令.html">
            
                    
                    做Java或者C++开发都应该知道的lsof命令
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="3.1.3" data-path="../程序员必知必会的网络命令/Linux网络故障排查的瑞士军刀.html">
            
                <a href="../程序员必知必会的网络命令/Linux网络故障排查的瑞士军刀.html">
            
                    
                    Linux网络故障排查的瑞士军刀nc命令
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="3.1.4" data-path="../程序员必知必会的网络命令/Linuxtcpdump使用介绍.html">
            
                <a href="../程序员必知必会的网络命令/Linuxtcpdump使用介绍.html">
            
                    
                    Linux tcpdump使用详解
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="3.1.5" data-path="../程序员必知必会的网络命令/从抓包的角度分析connect函数的连接过程.html">
            
                <a href="../程序员必知必会的网络命令/从抓包的角度分析connect函数的连接过程.html">
            
                    
                    从抓包的角度分析connect函数的连接过程
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="3.1.6" data-path="../程序员必知必会的网络命令/服务器开发中网络数据分析与故障排查经验漫谈.html">
            
                <a href="../程序员必知必会的网络命令/服务器开发中网络数据分析与故障排查经验漫谈.html">
            
                    
                    服务器开发中网络数据分析与故障排查经验漫谈
            
                </a>
            

            
        </li>
    

            </ul>
            
        </li>
    

    
        
        <li class="header">Part II</li>
        
        
    
        <li class="chapter " data-level="4.1" data-path="../高性能服务器框架设计/">
            
                <a href="../高性能服务器框架设计/">
            
                    
                    高性能服务器框架设计
            
                </a>
            

            
            <ul class="articles">
                
    
        <li class="chapter " data-level="4.1.1" data-path="../高性能服务器框架设计/主线程与工作线程的分工.html">
            
                <a href="../高性能服务器框架设计/主线程与工作线程的分工.html">
            
                    
                    主线程与工作线程的分工
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="4.1.2" data-path="../高性能服务器框架设计/Reactor模式.html">
            
                <a href="../高性能服务器框架设计/Reactor模式.html">
            
                    
                    Reactor模式
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="4.1.3" data-path="../高性能服务器框架设计/实例：一个服务器程序的架构介绍.html">
            
                <a href="../高性能服务器框架设计/实例：一个服务器程序的架构介绍.html">
            
                    
                    实例：一个服务器程序的架构介绍
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="4.1.4" data-path="../高性能服务器框架设计/错误码系统的设计.html">
            
                <a href="../高性能服务器框架设计/错误码系统的设计.html">
            
                    
                    错误码系统的设计
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="4.1.5" data-path="../高性能服务器框架设计/日志系统的设计.html">
            
                <a href="../高性能服务器框架设计/日志系统的设计.html">
            
                    
                    日志系统的设计
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="4.1.6" data-path="../高性能服务器框架设计/如何设计断线自动重连机制.html">
            
                <a href="../高性能服务器框架设计/如何设计断线自动重连机制.html">
            
                    
                    如何设计断线自动重连机制
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="4.1.7" data-path="../高性能服务器框架设计/心跳包机制设计详解.html">
            
                <a href="../高性能服务器框架设计/心跳包机制设计详解.html">
            
                    
                    心跳包机制设计详解
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="4.1.8" data-path="../高性能服务器框架设计/业务数据处理一定要单独开线程吗.html">
            
                <a href="../高性能服务器框架设计/业务数据处理一定要单独开线程吗.html">
            
                    
                    业务数据处理一定要单独开线程吗
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="4.1.9" data-path="../高性能服务器框架设计/C++高性能服务器网络框架设计细节.html">
            
                <a href="../高性能服务器框架设计/C++高性能服务器网络框架设计细节.html">
            
                    
                    C++ 高性能服务器网络框架设计细节
            
                </a>
            

            
        </li>
    

            </ul>
            
        </li>
    

    
        
        <li class="divider"></li>
        
        
    
        <li class="chapter " data-level="5.1" data-path="../服务器开发案例实战/">
            
                <a href="../服务器开发案例实战/">
            
                    
                    服务器开发案例实战
            
                </a>
            

            
            <ul class="articles">
                
    
        <li class="chapter " data-level="5.1.1" data-path="../服务器开发案例实战/从零实现一个http服务器.html">
            
                <a href="../服务器开发案例实战/从零实现一个http服务器.html">
            
                    
                    从零实现一个http服务器
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="5.1.2" data-path="../服务器开发案例实战/从零实现一款12306刷票软件.html">
            
                <a href="../服务器开发案例实战/从零实现一款12306刷票软件.html">
            
                    
                    从零实现一款12306刷票软件
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="5.1.3" data-path="../服务器开发案例实战/从零实现一个邮件收发客户端.html">
            
                <a href="../服务器开发案例实战/从零实现一个邮件收发客户端.html">
            
                    
                    从零实现一个邮件收发客户端
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="5.1.4" data-path="../服务器开发案例实战/从零开发一个WebSocket服务器.html">
            
                <a href="../服务器开发案例实战/从零开发一个WebSocket服务器.html">
            
                    
                    从零开发一个WebSocket服务器
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="5.1.5" data-path="../服务器开发案例实战/1从一款多人联机实时对战游戏开始.html">
            
                <a href="../服务器开发案例实战/1从一款多人联机实时对战游戏开始.html">
            
                    
                    从零学习开源项目系列（一） 从一款多人联机实时对战游戏开始
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="5.1.6" data-path="../服务器开发案例实战/2最后一战概况.html">
            
                <a href="../服务器开发案例实战/2最后一战概况.html">
            
                    
                    从零学习开源项目系列（二） 最后一战概况
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="5.1.7" data-path="../服务器开发案例实战/3CSBattleMgr服务源码研究.html">
            
                <a href="../服务器开发案例实战/3CSBattleMgr服务源码研究.html">
            
                    
                    从零学习开源项目系列（三） CSBattleMgr服务源码研究
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="5.1.8" data-path="../服务器开发案例实战/4LogServer源码探究.html">
            
                <a href="../服务器开发案例实战/4LogServer源码探究.html">
            
                    
                    从零学习开源项目系列（四）LogServer源码探究
            
                </a>
            

            
        </li>
    

            </ul>
            
        </li>
    

    
        
        <li class="header">Part III</li>
        
        
    
        <li class="chapter " data-level="6.1" data-path="../TeamTalk源码解析/">
            
                <a href="../TeamTalk源码解析/">
            
                    
                    TeamTalk IM源码分析
            
                </a>
            

            
            <ul class="articles">
                
    
        <li class="chapter " data-level="6.1.1" data-path="../TeamTalk源码解析/01TeamTalk介绍.html">
            
                <a href="../TeamTalk源码解析/01TeamTalk介绍.html">
            
                    
                    01 TeamTalk介绍
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="6.1.2" data-path="../TeamTalk源码解析/02服务器端的程序的编译与部署.html">
            
                <a href="../TeamTalk源码解析/02服务器端的程序的编译与部署.html">
            
                    
                    02 服务器端的程序的编译与部署
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="6.1.3" data-path="../TeamTalk源码解析/03服务器端的程序架构介绍.html">
            
                <a href="../TeamTalk源码解析/03服务器端的程序架构介绍.html">
            
                    
                    03 服务器端的程序架构介绍
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="6.1.4" data-path="../TeamTalk源码解析/04服务器端db_proxy_server源码分析.html">
            
                <a href="../TeamTalk源码解析/04服务器端db_proxy_server源码分析.html">
            
                    
                    04 服务器端db_proxy_server源码分析
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="6.1.5" data-path="../TeamTalk源码解析/05服务器端msg_server源码分析.html">
            
                <a href="../TeamTalk源码解析/05服务器端msg_server源码分析.html">
            
                    
                    05 服务器端msg_server源码分析
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="6.1.6" data-path="../TeamTalk源码解析/06服务器端login_server源码分析.html">
            
                <a href="../TeamTalk源码解析/06服务器端login_server源码分析.html">
            
                    
                    06 服务器端login_server源码分析
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="6.1.7" data-path="../TeamTalk源码解析/07服务器端msfs源码分析.html">
            
                <a href="../TeamTalk源码解析/07服务器端msfs源码分析.html">
            
                    
                    07 服务器端msfs源码分析
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="6.1.8" data-path="../TeamTalk源码解析/08服务器端file_server源码分析.html">
            
                <a href="../TeamTalk源码解析/08服务器端file_server源码分析.html">
            
                    
                    08 服务器端file_server源码分析
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="6.1.9" data-path="../TeamTalk源码解析/09服务器端route_server源码分析.html">
            
                <a href="../TeamTalk源码解析/09服务器端route_server源码分析.html">
            
                    
                    09 服务器端route_server源码分析
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="6.1.10" data-path="../TeamTalk源码解析/10开放一个TeamTalk测试服务器地址和几个测试账号.html">
            
                <a href="../TeamTalk源码解析/10开放一个TeamTalk测试服务器地址和几个测试账号.html">
            
                    
                    10 开放一个TeamTalk测试服务器地址和几个测试账号
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="6.1.11" data-path="../TeamTalk源码解析/11pc客户端源码分析.html">
            
                <a href="../TeamTalk源码解析/11pc客户端源码分析.html">
            
                    
                    11 pc客户端源码分析
            
                </a>
            

            
        </li>
    

            </ul>
            
        </li>
    

    
        
        <li class="divider"></li>
        
        
    
        <li class="chapter " data-level="7.1" data-path="../libevent源码深度剖析/">
            
                <a href="../libevent源码深度剖析/">
            
                    
                    libevent源码深度剖析
            
                </a>
            

            
            <ul class="articles">
                
    
        <li class="chapter " data-level="7.1.1" data-path="../libevent源码深度剖析/libevent源码深度剖析01.html">
            
                <a href="../libevent源码深度剖析/libevent源码深度剖析01.html">
            
                    
                    libevent源码深度剖析01
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="7.1.2" data-path="../libevent源码深度剖析/libevent源码深度剖析02.html">
            
                <a href="../libevent源码深度剖析/libevent源码深度剖析02.html">
            
                    
                    libevent源码深度剖析02
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="7.1.3" data-path="../libevent源码深度剖析/libevent源码深度剖析03.html">
            
                <a href="../libevent源码深度剖析/libevent源码深度剖析03.html">
            
                    
                    libevent源码深度剖析03
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="7.1.4" data-path="../libevent源码深度剖析/libevent源码深度剖析04.html">
            
                <a href="../libevent源码深度剖析/libevent源码深度剖析04.html">
            
                    
                    libevent源码深度剖析04
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="7.1.5" data-path="../libevent源码深度剖析/libevent源码深度剖析05.html">
            
                <a href="../libevent源码深度剖析/libevent源码深度剖析05.html">
            
                    
                    libevent源码深度剖析05
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="7.1.6" data-path="../libevent源码深度剖析/libevent源码深度剖析06.html">
            
                <a href="../libevent源码深度剖析/libevent源码深度剖析06.html">
            
                    
                    libevent源码深度剖析06
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="7.1.7" data-path="../libevent源码深度剖析/libevent源码深度剖析07.html">
            
                <a href="../libevent源码深度剖析/libevent源码深度剖析07.html">
            
                    
                    libevent源码深度剖析07
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="7.1.8" data-path="../libevent源码深度剖析/libevent源码深度剖析08.html">
            
                <a href="../libevent源码深度剖析/libevent源码深度剖析08.html">
            
                    
                    libevent源码深度剖析08
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="7.1.9" data-path="../libevent源码深度剖析/libevent源码深度剖析09.html">
            
                <a href="../libevent源码深度剖析/libevent源码深度剖析09.html">
            
                    
                    libevent源码深度剖析09
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="7.1.10" data-path="../libevent源码深度剖析/libevent源码深度剖析10.html">
            
                <a href="../libevent源码深度剖析/libevent源码深度剖析10.html">
            
                    
                    libevent源码深度剖析10
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="7.1.11" data-path="../libevent源码深度剖析/libevent源码深度剖析11.html">
            
                <a href="../libevent源码深度剖析/libevent源码深度剖析11.html">
            
                    
                    libevent源码深度剖析11
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="7.1.12" data-path="../libevent源码深度剖析/libevent源码深度剖析12.html">
            
                <a href="../libevent源码深度剖析/libevent源码深度剖析12.html">
            
                    
                    libevent源码深度剖析12
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="7.1.13" data-path="../libevent源码深度剖析/libevent源码深度剖析13.html">
            
                <a href="../libevent源码深度剖析/libevent源码深度剖析13.html">
            
                    
                    libevent源码深度剖析13
            
                </a>
            

            
        </li>
    

            </ul>
            
        </li>
    
        <li class="chapter " data-level="7.2" data-path="./">
            
                <a href="./">
            
                    
                    leveldb源码分析
            
                </a>
            

            
            <ul class="articles">
                
    
        <li class="chapter " data-level="7.2.1" data-path="leveldb源码分析1.html">
            
                <a href="leveldb源码分析1.html">
            
                    
                    leveldb源码分析1
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="7.2.2" data-path="leveldb源码分析2.html">
            
                <a href="leveldb源码分析2.html">
            
                    
                    leveldb源码分析2
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="7.2.3" data-path="leveldb源码分析3.html">
            
                <a href="leveldb源码分析3.html">
            
                    
                    leveldb源码分析3
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="7.2.4" data-path="leveldb源码分析4.html">
            
                <a href="leveldb源码分析4.html">
            
                    
                    leveldb源码分析4
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="7.2.5" data-path="leveldb源码分析5.html">
            
                <a href="leveldb源码分析5.html">
            
                    
                    leveldb源码分析5
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="7.2.6" data-path="leveldb源码分析6.html">
            
                <a href="leveldb源码分析6.html">
            
                    
                    leveldb源码分析6
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="7.2.7" data-path="leveldb源码分析7.html">
            
                <a href="leveldb源码分析7.html">
            
                    
                    leveldb源码分析7
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="7.2.8" data-path="leveldb源码分析8.html">
            
                <a href="leveldb源码分析8.html">
            
                    
                    leveldb源码分析8
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="7.2.9" data-path="leveldb源码分析9.html">
            
                <a href="leveldb源码分析9.html">
            
                    
                    leveldb源码分析9
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="7.2.10" data-path="leveldb源码分析10.html">
            
                <a href="leveldb源码分析10.html">
            
                    
                    leveldb源码分析10
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="7.2.11" data-path="leveldb源码分析11.html">
            
                <a href="leveldb源码分析11.html">
            
                    
                    leveldb源码分析11
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="7.2.12" data-path="leveldb源码分析12.html">
            
                <a href="leveldb源码分析12.html">
            
                    
                    leveldb源码分析12
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="7.2.13" data-path="leveldb源码分析13.html">
            
                <a href="leveldb源码分析13.html">
            
                    
                    leveldb源码分析13
            
                </a>
            

            
        </li>
    
        <li class="chapter active" data-level="7.2.14" data-path="leveldb源码分析14.html">
            
                <a href="leveldb源码分析14.html">
            
                    
                    leveldb源码分析14
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="7.2.15" data-path="leveldb源码分析15.html">
            
                <a href="leveldb源码分析15.html">
            
                    
                    leveldb源码分析15
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="7.2.16" data-path="leveldb源码分析16.html">
            
                <a href="leveldb源码分析16.html">
            
                    
                    leveldb源码分析16
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="7.2.17" data-path="leveldb源码分析17.html">
            
                <a href="leveldb源码分析17.html">
            
                    
                    leveldb源码分析17
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="7.2.18" data-path="leveldb源码分析18.html">
            
                <a href="leveldb源码分析18.html">
            
                    
                    leveldb源码分析18
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="7.2.19" data-path="leveldb源码分析19.html">
            
                <a href="leveldb源码分析19.html">
            
                    
                    leveldb源码分析19
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="7.2.20" data-path="leveldb源码分析20.html">
            
                <a href="leveldb源码分析20.html">
            
                    
                    leveldb源码分析20
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="7.2.21" data-path="leveldb源码分析21.html">
            
                <a href="leveldb源码分析21.html">
            
                    
                    leveldb源码分析21
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="7.2.22" data-path="leveldb源码分析22.html">
            
                <a href="leveldb源码分析22.html">
            
                    
                    leveldb源码分析22
            
                </a>
            

            
        </li>
    

            </ul>
            
        </li>
    

    
        
        <li class="divider"></li>
        
        
    
        <li class="chapter " data-level="8.1" data-path="../Memcached源码分析/">
            
                <a href="../Memcached源码分析/">
            
                    
                    Memcached源码分析
            
                </a>
            

            
            <ul class="articles">
                
    
        <li class="chapter " data-level="8.1.1" data-path="../Memcached源码分析/00服务器资源调整.html">
            
                <a href="../Memcached源码分析/00服务器资源调整.html">
            
                    
                    00 服务器资源调整
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="8.1.2" data-path="../Memcached源码分析/01初始化参数解析.html">
            
                <a href="../Memcached源码分析/01初始化参数解析.html">
            
                    
                    01 初始化参数解析
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="8.1.3" data-path="../Memcached源码分析/02网络监听的建立.html">
            
                <a href="../Memcached源码分析/02网络监听的建立.html">
            
                    
                    02 网络监听的建立
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="8.1.4" data-path="../Memcached源码分析/03网络连接建立.html">
            
                <a href="../Memcached源码分析/03网络连接建立.html">
            
                    
                    03 网络连接建立
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="8.1.5" data-path="../Memcached源码分析/04内存初始化.html">
            
                <a href="../Memcached源码分析/04内存初始化.html">
            
                    
                    04 内存初始化
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="8.1.6" data-path="../Memcached源码分析/05资源初始化.html">
            
                <a href="../Memcached源码分析/05资源初始化.html">
            
                    
                    05 资源初始化
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="8.1.7" data-path="../Memcached源码分析/06get过程.html">
            
                <a href="../Memcached源码分析/06get过程.html">
            
                    
                    06 get过程
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="8.1.8" data-path="../Memcached源码分析/07cas属性.html">
            
                <a href="../Memcached源码分析/07cas属性.html">
            
                    
                    07 cas属性
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="8.1.9" data-path="../Memcached源码分析/08内存池.html">
            
                <a href="../Memcached源码分析/08内存池.html">
            
                    
                    08 内存池
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="8.1.10" data-path="../Memcached源码分析/09连接队列.html">
            
                <a href="../Memcached源码分析/09连接队列.html">
            
                    
                    09 连接队列
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="8.1.11" data-path="../Memcached源码分析/10Hash表操作.html">
            
                <a href="../Memcached源码分析/10Hash表操作.html">
            
                    
                    10 Hash表操作
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="8.1.12" data-path="../Memcached源码分析/12set操作.html">
            
                <a href="../Memcached源码分析/12set操作.html">
            
                    
                    12 set操作
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="8.1.13" data-path="../Memcached源码分析/13do_item_alloc操作.html">
            
                <a href="../Memcached源码分析/13do_item_alloc操作.html">
            
                    
                    13 do_item_alloc操作
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="8.1.14" data-path="../Memcached源码分析/14item结构.html">
            
                <a href="../Memcached源码分析/14item结构.html">
            
                    
                    14 item结构
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="8.1.15" data-path="../Memcached源码分析/15Hash表扩容.html">
            
                <a href="../Memcached源码分析/15Hash表扩容.html">
            
                    
                    15 Hash表扩容
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="8.1.16" data-path="../Memcached源码分析/16线程交互.html">
            
                <a href="../Memcached源码分析/16线程交互.html">
            
                    
                    16 线程交互
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="8.1.17" data-path="../Memcached源码分析/17状态机.html">
            
                <a href="../Memcached源码分析/17状态机.html">
            
                    
                    17 状态机
            
                </a>
            

            
        </li>
    

            </ul>
            
        </li>
    

    
        
        <li class="divider"></li>
        
        
    
        <li class="chapter " data-level="9.1" data-path="../游戏开发专题/">
            
                <a href="../游戏开发专题/">
            
                    
                    游戏开发专题
            
                </a>
            

            
            <ul class="articles">
                
    
        <li class="chapter " data-level="9.1.1" data-path="../游戏开发专题/1游戏服务器开发的基本体系与服务器端开发的一些建议.html">
            
                <a href="../游戏开发专题/1游戏服务器开发的基本体系与服务器端开发的一些建议.html">
            
                    
                    1 游戏服务器开发的基本体系与服务器端开发的一些建议
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="9.1.2" data-path="../游戏开发专题/2网络游戏服务器开发框架设计介绍.html">
            
                <a href="../游戏开发专题/2网络游戏服务器开发框架设计介绍.html">
            
                    
                    2 网络游戏服务器开发框架设计介绍
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="9.1.3" data-path="../游戏开发专题/3游戏后端开发需要掌握的知识.html">
            
                <a href="../游戏开发专题/3游戏后端开发需要掌握的知识.html">
            
                    
                    3 游戏后端开发需要掌握的知识
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="9.1.4" data-path="../游戏开发专题/4关于游戏服务端架构的整理.html">
            
                <a href="../游戏开发专题/4关于游戏服务端架构的整理.html">
            
                    
                    4 关于游戏服务端架构的整理
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="9.1.5" data-path="../游戏开发专题/5各类游戏对应的服务端架构.html">
            
                <a href="../游戏开发专题/5各类游戏对应的服务端架构.html">
            
                    
                    5 各类游戏对应的服务端架构
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="9.1.6" data-path="../游戏开发专题/6从腾讯QQgame高性能服务器集群架构看“分而治之”与“自治”等分布式架构设计原则.html">
            
                <a href="../游戏开发专题/6从腾讯QQgame高性能服务器集群架构看“分而治之”与“自治”等分布式架构设计原则.html">
            
                    
                    6 从腾讯QQgame高性能服务器集群架构看“分而治之”与“自治”等分布式架构设计原则
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="9.1.7" data-path="../游戏开发专题/7QQ游戏百万人同时在线服务器架构实现.html">
            
                <a href="../游戏开发专题/7QQ游戏百万人同时在线服务器架构实现.html">
            
                    
                    7 QQ游戏百万人同时在线服务器架构实现
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="9.1.8" data-path="../游戏开发专题/8大型多人在线游戏服务器架构设计.html">
            
                <a href="../游戏开发专题/8大型多人在线游戏服务器架构设计.html">
            
                    
                    8 大型多人在线游戏服务器架构设计
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="9.1.9" data-path="../游戏开发专题/9百万用户级游戏服务器架构设计.html">
            
                <a href="../游戏开发专题/9百万用户级游戏服务器架构设计.html">
            
                    
                    9 百万用户级游戏服务器架构设计
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="9.1.10" data-path="../游戏开发专题/10十万在线的WebGame的数据库设计思路.html">
            
                <a href="../游戏开发专题/10十万在线的WebGame的数据库设计思路.html">
            
                    
                    10 十万在线的WebGame的数据库设计思路
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="9.1.11" data-path="../游戏开发专题/11一种高性能网络游戏服务器架构设计.html">
            
                <a href="../游戏开发专题/11一种高性能网络游戏服务器架构设计.html">
            
                    
                    11 一种高性能网络游戏服务器架构设计
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="9.1.12" data-path="../游戏开发专题/12经典游戏服务器端架构概述.html">
            
                <a href="../游戏开发专题/12经典游戏服务器端架构概述.html">
            
                    
                    12 经典游戏服务器端架构概述
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="9.1.13" data-path="../游戏开发专题/13游戏跨服架构进化之路.html">
            
                <a href="../游戏开发专题/13游戏跨服架构进化之路.html">
            
                    
                    13 游戏跨服架构进化之路
            
                </a>
            

            
        </li>
    

            </ul>
            
        </li>
    

    
        
        <li class="header">Part IV</li>
        
        
    
        <li class="chapter " data-level="10.1" data-path="../程序员面试题精讲/">
            
                <a href="../程序员面试题精讲/">
            
                    
                    程序员面试题精讲
            
                </a>
            

            
            <ul class="articles">
                
    
        <li class="chapter " data-level="10.1.1" data-path="../程序员面试题精讲/腾讯后台开发实习生技能要求.html">
            
                <a href="../程序员面试题精讲/腾讯后台开发实习生技能要求.html">
            
                    
                    腾讯后台开发实习生技能要求
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="10.1.2" data-path="../程序员面试题精讲/聊聊如何拿大厂的offer.html">
            
                <a href="../程序员面试题精讲/聊聊如何拿大厂的offer.html">
            
                    
                    聊聊如何拿大厂的 offer
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="10.1.3" data-path="../程序员面试题精讲/网络通信题目集锦.html">
            
                <a href="../程序员面试题精讲/网络通信题目集锦.html">
            
                    
                    网络通信题目集锦
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="10.1.4" data-path="../程序员面试题精讲/我面试后端开发经理的经历.html">
            
                <a href="../程序员面试题精讲/我面试后端开发经理的经历.html">
            
                    
                    我面试后端开发经理的经历
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="10.1.5" data-path="../程序员面试题精讲/LinuxCC++后端开发面试问哪些问题.html">
            
                <a href="../程序员面试题精讲/LinuxCC++后端开发面试问哪些问题.html">
            
                    
                    Linux C/C++后端开发面试问哪些问题
            
                </a>
            

            
        </li>
    

            </ul>
            
        </li>
    
        <li class="chapter " data-level="10.2" data-path="../职业规划/">
            
                <a href="../职业规划/">
            
                    
                    职业规划
            
                </a>
            

            
            <ul class="articles">
                
    
        <li class="chapter " data-level="10.2.1" data-path="../职业规划/给工作4年迷茫的程序员们的一点建议.html">
            
                <a href="../职业规划/给工作4年迷茫的程序员们的一点建议.html">
            
                    
                    给工作 4 年迷茫的程序员们的一点建议
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="10.2.2" data-path="../职业规划/聊聊技术人员的常见的职业问题.html">
            
                <a href="../职业规划/聊聊技术人员的常见的职业问题.html">
            
                    
                    聊聊技术人员的常见的职业问题
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="10.2.3" data-path="../职业规划/写给那些傻傻想做服务器开发的朋友.html">
            
                <a href="../职业规划/写给那些傻傻想做服务器开发的朋友.html">
            
                    
                    写给那些傻傻想做服务器开发的朋友
            
                </a>
            

            
        </li>
    

            </ul>
            
        </li>
    
        <li class="chapter " data-level="10.3" data-path="../自我提升与开源代码/">
            
                <a href="../自我提升与开源代码/">
            
                    
                    自我提升与开源代码
            
                </a>
            

            
            <ul class="articles">
                
    
        <li class="chapter " data-level="10.3.1" data-path="../自我提升与开源代码/2020年好好读一读开源代码吧.html">
            
                <a href="../自我提升与开源代码/2020年好好读一读开源代码吧.html">
            
                    
                    2020 年好好读一读开源代码吧
            
                </a>
            

            
        </li>
    

            </ul>
            
        </li>
    
        <li class="chapter " data-level="10.4" data-path="../后端开发相关的书籍/">
            
                <a href="../后端开发相关的书籍/">
            
                    
                    后端开发相关的书籍
            
                </a>
            

            
            <ul class="articles">
                
    
        <li class="chapter " data-level="10.4.1" data-path="../后端开发相关的书籍/后台开发应该读的书.html">
            
                <a href="../后端开发相关的书籍/后台开发应该读的书.html">
            
                    
                    后台开发应该读的书
            
                </a>
            

            
        </li>
    

            </ul>
            
        </li>
    
        <li class="chapter " data-level="10.5" data-path="../程序员的简历/">
            
                <a href="../程序员的简历/">
            
                    
                    程序员的简历
            
                </a>
            

            
            <ul class="articles">
                
    
        <li class="chapter " data-level="10.5.1" data-path="../程序员的简历/程序员如何写简历.html">
            
                <a href="../程序员的简历/程序员如何写简历.html">
            
                    
                    程序员如何写简历
            
                </a>
            

            
        </li>
    

            </ul>
            
        </li>
    
        <li class="chapter " data-level="10.6" data-path="../程序员的薪资与年终奖那些事儿/">
            
                <a href="../程序员的薪资与年终奖那些事儿/">
            
                    
                    程序员的薪资与年终奖那些事儿
            
                </a>
            

            
            <ul class="articles">
                
    
        <li class="chapter " data-level="10.6.1" data-path="../程序员的薪资与年终奖那些事儿/技术面试与HR谈薪资技巧.html">
            
                <a href="../程序员的薪资与年终奖那些事儿/技术面试与HR谈薪资技巧.html">
            
                    
                    技术面试与HR谈薪资技巧
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="10.6.2" data-path="../程序员的薪资与年终奖那些事儿/聊一聊程序员如何增加收入.html">
            
                <a href="../程序员的薪资与年终奖那些事儿/聊一聊程序员如何增加收入.html">
            
                    
                    聊一聊程序员如何增加收入
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="10.6.3" data-path="../程序员的薪资与年终奖那些事儿/谈一谈年终奖.html">
            
                <a href="../程序员的薪资与年终奖那些事儿/谈一谈年终奖.html">
            
                    
                    谈一谈年终奖
            
                </a>
            

            
        </li>
    

            </ul>
            
        </li>
    
        <li class="chapter " data-level="10.7" data-path="../程序员的烦心事/">
            
                <a href="../程序员的烦心事/">
            
                    
                    程序员的烦心事
            
                </a>
            

            
            <ul class="articles">
                
    
        <li class="chapter " data-level="10.7.1" data-path="../程序员的烦心事/拒绝了一家公司的offer后，他们的副总和hr总监同时打电话来询问拒绝原因并极力要求加入，我该不该去？.html">
            
                <a href="../程序员的烦心事/拒绝了一家公司的offer后，他们的副总和hr总监同时打电话来询问拒绝原因并极力要求加入，我该不该去？.html">
            
                    
                    拒绝了一家公司的offer后，他们的副总和hr总监同时打电话来询问拒绝原因并极力要求加入，我该不该去？
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="10.7.2" data-path="../程序员的烦心事/我是一名程序员，结婚时女友要求我用两年的工资作为彩礼，我该不该答应？.html">
            
                <a href="../程序员的烦心事/我是一名程序员，结婚时女友要求我用两年的工资作为彩礼，我该不该答应？.html">
            
                    
                    我是一名程序员，结婚时女友要求我用两年的工资作为彩礼，我该不该答应？
            
                </a>
            

            
        </li>
    

            </ul>
            
        </li>
    
        <li class="chapter " data-level="10.8" data-path="../作者的故事/">
            
                <a href="../作者的故事/">
            
                    
                    作者的故事
            
                </a>
            

            
            <ul class="articles">
                
    
        <li class="chapter " data-level="10.8.1" data-path="../作者的故事/我的2019.html">
            
                <a href="../作者的故事/我的2019.html">
            
                    
                    我的 2019
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="10.8.2" data-path="../作者的故事/我是如何年薪五十万的.html">
            
                <a href="../作者的故事/我是如何年薪五十万的.html">
            
                    
                    我是如何年薪五十万的
            
                </a>
            

            
        </li>
    

            </ul>
            
        </li>
    

    

    <li class="divider"></li>

    <li>
        <a href="https://www.gitbook.com" target="blank" class="gitbook-link">
            Published with GitBook
        </a>
    </li>
</ul>


		</nav>
		
		
	</div>

	<!-- Content nav -->
	<div class="book-anchor">
		<div class="book-anchor-title">在这篇文章中:</div>
		<div class="book-anchor-body">

		</div>
	</div>

	<div class="book-body">
		
		<div class="body-inner">
			
			

<div class="book-header" role="navigation">
    

    <!-- Title -->
    <h1>
        <i class="fa fa-circle-o-notch fa-spin"></i>
        <a href="../.." >leveldb源码分析14</a>
    </h1>
</div>




			<div class="page-wrapper" tabindex="-1" role="main">
				<div class="page-inner">
					
<div id="book-search-results">
    <div class="search-noresults">
    
					<section class="normal markdown-section">
						
						<div id="anchor-navigation-ex-navbar"><i class="fa fa-navicon"></i><ul><li><span class="title-icon "></span><a href="#leveldb&#x6E90;&#x7801;&#x5206;&#x6790;14"><b></b>leveldb&#x6E90;&#x7801;&#x5206;&#x6790;14</a></li><ul><ul><li><span class="title-icon "></span><a href="#91-db&#x6587;&#x4EF6;&#x7BA1;&#x7406;"><b></b>9.1 DB&#x6587;&#x4EF6;&#x7BA1;&#x7406;</a></li><li><span class="title-icon "></span><a href="#92-compaction"><b></b>9.2 Compaction</a></li><li><span class="title-icon "></span><a href="#93-recovery--gc"><b></b>9.3 Recovery &amp; GC</a></li></ul></ul></ul></div><h1 id="leveldb&#x6E90;&#x7801;&#x5206;&#x6790;14"><a name="leveldb&#x6E90;&#x7801;&#x5206;&#x6790;14" class="anchor-navigation-ex-anchor" href="#leveldb&#x6E90;&#x7801;&#x5206;&#x6790;14"><i class="fa fa-link" aria-hidden="true"></i></a>leveldb&#x6E90;&#x7801;&#x5206;&#x6790;14</h1>
<p>&#x672C;&#x7CFB;&#x5217;&#x300A;leveldb&#x6E90;&#x7801;&#x5206;&#x6790;&#x300B;&#x5171;&#x6709;22&#x7BC7;&#x6587;&#x7AE0;&#xFF0C;&#x8FD9;&#x662F;&#x7B2C;&#x5341;&#x56DB;&#x7BC7;</p>
<p><strong>9 LevelDB&#x6846;&#x67B6;&#x4E4B;1</strong></p>
<p>&#x5230;&#x6B64;&#x4E3A;&#x6B62;&#xFF0C;&#x57FA;&#x672C;&#x4E0A;<code>Leveldb</code>&#x7684;&#x4E3B;&#x8981;&#x529F;&#x80FD;&#x7EC4;&#x4EF6;&#x90FD;&#x5DF2;&#x7ECF;&#x5206;&#x6790;&#x5B8C;&#x4E86;&#xFF0C;&#x4E0B;&#x9762;&#x5C31;&#x662F;&#x628A;&#x5B83;&#x4EEC;&#x7EC4;&#x5408;&#x5728;&#x4E00;&#x8D77;&#xFF0C;&#x5F62;&#x6210;&#x4E00;&#x4E2A;&#x9AD8;&#x6027;&#x80FD;&#x7684;k/v&#x5B58;&#x50A8;&#x7CFB;&#x7EDF;&#x3002;&#x8FD9;&#x5C31;&#x662F;<code>leveldb::DB</code>&#x7C7B;&#x3002;
&#x8FD9;&#x91CC;&#x5148;&#x770B;&#x4E00;&#x4E0B;LevelDB&#x7684;&#x5BFC;&#x51FA;&#x63A5;&#x53E3;&#x548C;&#x6D89;&#x53CA;&#x7684;&#x7C7B;&#xFF0C;&#x540E;&#x9762;&#x5C06;&#x4F9D;&#x6B21;&#x4EE5;&#x63A5;&#x53E3;&#x5206;&#x6790;&#x7684;&#x65B9;&#x5F0F;&#x5C55;&#x5F00;&#x3002;
&#x800C;&#x5B9E;&#x9645;&#x4E0A;leveldb::DB&#x53EA;&#x662F;&#x4E00;&#x4E2A;&#x63A5;&#x53E3;&#x7C7B;&#xFF0C;&#x771F;&#x6B63;&#x7684;&#x5B9E;&#x73B0;&#x548C;&#x6846;&#x67B6;&#x7C7B;&#x662F;DBImpl&#x8FD9;&#x4E2A;&#x7C7B;&#xFF0C;&#x6B63;&#x662F;&#x5B83;&#x96C6;&#x5408;&#x4E86;&#x4E0A;&#x9762;&#x7684;&#x5404;&#x79CD;&#x7EC4;&#x4EF6;&#x3002;
&#x6B64;&#x5916;&#xFF0C;&#x8FD8;&#x6709;Leveldb&#x5BF9;&#x7248;&#x672C;&#x7684;&#x63A7;&#x5236;&#xFF0C;&#x6267;&#x884C;&#x7248;&#x672C;&#x63A7;&#x5236;&#x7684;&#x662F;<code>Version</code>&#x548C;<code>VersionSet</code>&#x7C7B;&#x3002;
&#x5728;leveldb&#x7684;&#x6E90;&#x7801;&#x4E2D;&#xFF0C;DBImpl&#x548C;VersionSet&#x662F;&#x4E24;&#x4E2A;&#x5E9E;&#x7136;&#x5927;&#x7269;&#xFF0C;&#x4F53;&#x91CF;&#x57FA;&#x672C;&#x7B97;&#x662F;&#x6700;&#x5927;&#x7684;&#x3002;&#x5BF9;&#x4E8E;&#x8FD9;&#x4E24;&#x4E2A;&#x7C7B;&#x7684;&#x5206;&#x6790;&#xFF0C;&#x4E5F;&#x4F1A;&#x5206;&#x6563;&#x5728;&#x6253;&#x5F00;&#x3001;&#x9500;&#x6BC1;&#x548C;&#x5FEB;&#x7167;&#x7B49;&#x7B49;&#x8FD9;&#x4E9B;&#x529F;&#x80FD;&#x4E2D;&#xFF0C;&#x5F88;&#x96BE;&#x5728;&#x4E00;&#x4E2A;&#x5730;&#x65B9;&#x96C6;&#x4E2D;&#x5206;&#x6790;&#x3002;
&#x4F5C;&#x8005;&#x5728;&#x6587;&#x6863;impl.html&#x4E2D;&#x63CF;&#x8FF0;&#x4E86;leveldb&#x7684;&#x5B9E;&#x73B0;&#xFF0C;&#x5176;&#x4E2D;&#x5305;&#x62EC;<strong>&#x6587;&#x4EF6;&#x7EC4;&#x7EC7;</strong>&#x3001;<strong>compaction</strong>&#x548C;<strong>recovery</strong>&#x7B49;&#x7B49;&#x3002;&#x4E0B;&#x9762;&#x7684;9.1&#x548C;9.2&#x57FA;&#x672C;&#x90FD;&#x662F;&#x7FFB;&#x8BD1;&#x5B50;impl.html&#x6587;&#x6863;&#x3002;
&#x5728;&#x8FDB;&#x5165;&#x6846;&#x67B6;&#x4EE3;&#x7801;&#x4E4B;&#x524D;&#xFF0C;&#x5148;&#x6765;&#x4E86;&#x89E3;&#x4E0B;leveldb&#x7684;&#x6587;&#x4EF6;&#x7EC4;&#x7EC7;&#x548C;&#x7BA1;&#x7406;&#x3002;</p>
<h3 id="91-db&#x6587;&#x4EF6;&#x7BA1;&#x7406;"><a name="91-db&#x6587;&#x4EF6;&#x7BA1;&#x7406;" class="anchor-navigation-ex-anchor" href="#91-db&#x6587;&#x4EF6;&#x7BA1;&#x7406;"><i class="fa fa-link" aria-hidden="true"></i></a>9.1 DB&#x6587;&#x4EF6;&#x7BA1;&#x7406;</h3>
<p><strong>9.1.1 &#x6587;&#x4EF6;&#x7C7B;&#x578B;</strong></p>
<p>&#x5BF9;&#x4E8E;&#x4E00;&#x4E2A;&#x6570;&#x636E;&#x5E93;Level&#x5305;&#x542B;&#x5982;&#x4E0B;&#x7684;6&#x79CD;&#x6587;&#x4EF6;:</p>
<p><strong>1/[0-9]+.log&#xFF1A;db&#x64CD;&#x4F5C;&#x65E5;&#x5FD7;</strong>
&#x8FD9;&#x5C31;&#x662F;&#x524D;&#x9762;&#x5206;&#x6790;&#x8FC7;&#x7684;&#x64CD;&#x4F5C;&#x65E5;&#x5FD7;&#xFF0C;log&#x6587;&#x4EF6;&#x5305;&#x542B;&#x4E86;&#x6700;&#x65B0;&#x7684;db&#x66F4;&#x65B0;&#xFF0C;&#x6BCF;&#x4E2A;&#x66F4;&#x65B0;&#x90FD;&#x4EE5;<code>append</code>&#x7684;&#x65B9;&#x5F0F;&#x8FFD;&#x52A0;&#x5230;&#x6587;&#x4EF6;&#x7ED3;&#x5C3E;&#x3002;&#x5F53;log&#x6587;&#x4EF6;&#x8FBE;&#x5230;&#x9884;&#x5B9A;&#x5927;&#x5C0F;&#x65F6;&#xFF08;&#x7F3A;&#x7701;&#x5927;&#x7EA6;4MB&#xFF09;&#xFF0C;<code>leveldb</code>&#x5C31;&#x628A;&#x5B83;&#x8F6C;&#x6362;&#x4E3A;&#x4E00;&#x4E2A;&#x6709;&#x5E8F;&#x8868;&#xFF08;&#x5982;&#x4E0B;-2&#xFF09;&#xFF0C;&#x5E76;&#x521B;&#x5EFA;&#x4E00;&#x4E2A;&#x65B0;&#x7684;log&#x6587;&#x4EF6;&#x3002;
&#x5F53;&#x524D;&#x7684;log&#x6587;&#x4EF6;&#x5728;&#x5185;&#x5B58;&#x4E2D;&#x7684;&#x5B58;&#x5728;&#x5F62;&#x5F0F;&#x5C31;&#x662F;<code>memtable</code>&#xFF0C;&#x6BCF;&#x6B21;read&#x64CD;&#x4F5C;&#x90FD;&#x4F1A;&#x8BBF;&#x95EE;memtable&#xFF0C;&#x4EE5;&#x4FDD;&#x8BC1;read&#x8BFB;&#x53D6;&#x5230;&#x7684;&#x662F;&#x6700;&#x65B0;&#x7684;&#x6570;&#x636E;&#x3002;</p>
<p><strong>2/[0-9]+.sst&#xFF1A;db&#x7684;sstable&#x6587;&#x4EF6;</strong>
&#x8FD9;&#x4E24;&#x4E2A;&#x5C31;&#x662F;&#x524D;&#x9762;&#x5206;&#x6790;&#x8FC7;&#x7684;<strong>&#x9759;&#x6001;sstable&#x6587;&#x4EF6;</strong>&#xFF0C;sstable&#x5B58;&#x50A8;&#x4E86;&#x4EE5;key&#x6392;&#x5E8F;&#x7684;&#x5143;&#x7D20;&#x3002;&#x6BCF;&#x4E2A;&#x5143;&#x7D20;&#x6216;&#x8005;&#x662F;key&#x5BF9;&#x5E94;&#x7684;value&#xFF0C;&#x6216;&#x8005;&#x662F;key&#x7684;&#x5220;&#x9664;&#x6807;&#x8BB0;&#xFF08;&#x5220;&#x9664;&#x6807;&#x8BB0;&#x53EF;&#x4EE5;&#x63A9;&#x76D6;&#x66F4;&#x8001;sstable&#x6587;&#x4EF6;&#x4E2D;&#x8FC7;&#x671F;&#x7684;value&#xFF09;&#x3002;
<code>Leveldb</code>&#x628A;<code>sstable</code>&#x6587;&#x4EF6;&#x901A;&#x8FC7;level&#x7684;&#x65B9;&#x5F0F;&#x7EC4;&#x7EC7;&#x8D77;&#x6765;&#xFF0C;&#x4ECE;log&#x6587;&#x4EF6;&#x4E2D;&#x751F;&#x6210;&#x7684;sstable&#x88AB;&#x653E;&#x5728;level 0&#x3002;&#x5F53;level 0&#x7684;sstable&#x6587;&#x4EF6;&#x4E2A;&#x6570;&#x8D85;&#x8FC7;&#x8BBE;&#x7F6E;&#xFF08;&#x5F53;&#x524D;&#x4E3A;4&#x4E2A;&#xFF09;&#x65F6;&#xFF0C;leveldb&#x5C31;&#x628A;&#x6240;&#x6709;&#x7684;level 0&#x6587;&#x4EF6;&#xFF0C;&#x4EE5;&#x53CA;&#x6709;&#x91CD;&#x5408;&#x7684;level 1&#x6587;&#x4EF6;merge&#x8D77;&#x6765;&#xFF0C;&#x7EC4;&#x7EC7;&#x6210;&#x4E00;&#x4E2A;&#x65B0;&#x7684;level 1&#x6587;&#x4EF6;&#xFF08;&#x6BCF;&#x4E2A;level 1&#x6587;&#x4EF6;&#x5927;&#x5C0F;&#x4E3A;2MB&#xFF09;&#x3002;
Level 0&#x7684;SSTable&#x6587;&#x4EF6;&#xFF08;&#x540E;&#x7F00;&#x4E3A;.sst&#xFF09;&#x548C;Level&gt;1&#x7684;&#x6587;&#x4EF6;&#x76F8;&#x6BD4;&#x6709;&#x7279;&#x6B8A;&#x6027;&#xFF1A;&#x8FD9;&#x4E2A;&#x5C42;&#x7EA7;&#x5185;&#x7684;.sst&#x6587;&#x4EF6;&#xFF0C;&#x4E24;&#x4E2A;&#x6587;&#x4EF6;&#x53EF;&#x80FD;&#x5B58;&#x5728;key&#x91CD;&#x53E0;&#x3002;&#x5BF9;&#x4E8E;Level&gt;0&#xFF0C;&#x540C;&#x5C42;sstable&#x6587;&#x4EF6;&#x7684;key&#x4E0D;&#x4F1A;&#x91CD;&#x53E0;&#x3002;&#x8003;&#x8651;level&gt;0&#xFF0C;level&#x4E2D;&#x7684;&#x6587;&#x4EF6;&#x7684;&#x603B;&#x5927;&#x5C0F;&#x8D85;&#x8FC7;10^level MB&#x65F6;&#xFF08;&#x5982;level=1&#x662F;10MB&#xFF0C;level=2&#x662F;100MB&#xFF09;&#xFF0C;&#x90A3;&#x4E48;level&#x4E2D;&#x7684;&#x4E00;&#x4E2A;&#x6587;&#x4EF6;&#xFF0C;&#x4EE5;&#x53CA;&#x6240;&#x6709;level+1&#x4E2D;&#x548C;&#x5B83;&#x6709;&#x91CD;&#x53E0;&#x7684;&#x6587;&#x4EF6;&#xFF0C;&#x4F1A;&#x88AB;merge&#x5230;level+1&#x5C42;&#x7684;&#x4E00;&#x7CFB;&#x5217;&#x65B0;&#x6587;&#x4EF6;&#x3002;<strong>Merge&#x64CD;&#x4F5C;</strong>&#x7684;&#x4F5C;&#x7528;&#x662F;&#x5C06;&#x66F4;&#x65B0;&#x4ECE;&#x4F4E;&#x4E00;&#x7EA7;level&#x8FC1;&#x79FB;&#x5230;&#x6700;&#x9AD8;&#x7EA7;&#xFF0C;&#x53EA;&#x4F7F;&#x7528;&#x6279;&#x91CF;&#x8BFB;&#x5199;&#xFF08;&#x6700;&#x5C0F;&#x5316;seek&#x64CD;&#x4F5C;&#xFF0C;&#x63D0;&#x9AD8;&#x6548;&#x7387;&#xFF09;&#x3002;</p>
<p><strong>3/MANIFEST-[0-9]+&#xFF1A;DB&#x5143;&#x4FE1;&#x606F;&#x6587;&#x4EF6;</strong>
&#x5B83;&#x8BB0;&#x5F55;&#x7684;&#x662F;leveldb&#x7684;&#x5143;&#x4FE1;&#x606F;&#xFF0C;&#x6BD4;&#x5982;DB&#x4F7F;&#x7528;&#x7684;Comparator&#x540D;&#xFF0C;&#x4EE5;&#x53CA;&#x5404;SSTable&#x6587;&#x4EF6;&#x7684;&#x7BA1;&#x7406;&#x4FE1;&#x606F;&#xFF1A;&#x5982;Level&#x5C42;&#x6570;&#x3001;&#x6587;&#x4EF6;&#x540D;&#x3001;&#x6700;&#x5C0F;key&#x548C;&#x6700;&#x5927;key&#x7B49;&#x7B49;&#x3002;</p>
<p><strong>4/CURRENT&#xFF1A;&#x8BB0;&#x5F55;&#x5F53;&#x524D;&#x6B63;&#x5728;&#x4F7F;&#x7528;&#x7684;Manifest&#x6587;&#x4EF6;</strong>
&#x5B83;&#x7684;&#x5185;&#x5BB9;&#x5C31;&#x662F;&#x5F53;&#x524D;&#x7684;<code>manifest</code>&#x6587;&#x4EF6;&#x540D;&#xFF1B;&#x56E0;&#x4E3A;&#x5728;LevleDb&#x7684;&#x8FD0;&#x884C;&#x8FC7;&#x7A0B;&#x4E2D;&#xFF0C;&#x968F;&#x7740;<code>Compaction</code>&#x7684;&#x8FDB;&#x884C;&#xFF0C;&#x65B0;&#x7684;<code>SSTable</code>&#x6587;&#x4EF6;&#x88AB;&#x4EA7;&#x751F;&#xFF0C;&#x8001;&#x7684;&#x6587;&#x4EF6;&#x88AB;&#x5E9F;&#x5F03;&#x3002;&#x5E76;&#x751F;&#x6210;&#x65B0;&#x7684;Manifest&#x6587;&#x4EF6;&#x6765;&#x8BB0;&#x8F7D;<code>sstable</code>&#x7684;&#x53D8;&#x52A8;&#xFF0C;&#x800C;<code>CURRENT</code>&#x5219;&#x7528;&#x6765;&#x8BB0;&#x5F55;&#x6211;&#x4EEC;&#x5173;&#x5FC3;&#x7684;Manifest&#x6587;&#x4EF6;&#x3002;
&#x5F53;db&#x88AB;&#x91CD;&#x65B0;&#x6253;&#x5F00;&#x65F6;&#xFF0C;leveldb&#x603B;&#x662F;&#x751F;&#x4EA7;&#x4E00;&#x4E2A;&#x65B0;&#x7684;manifest&#x6587;&#x4EF6;&#x3002;Manifest&#x6587;&#x4EF6;&#x4F7F;&#x7528;log&#x7684;&#x683C;&#x5F0F;&#xFF0C;&#x5BF9;&#x670D;&#x52A1;&#x72B6;&#x6001;&#x7684;&#x6539;&#x53D8;&#xFF08;&#x65B0;&#x52A0;&#x6216;&#x5220;&#x9664;&#x7684;&#x6587;&#x4EF6;&#xFF09;&#x90FD;&#x4F1A;&#x8FFD;&#x52A0;&#x5230;&#x8BE5;log&#x4E2D;&#x3002;
&#x4E0A;&#x9762;&#x7684;log&#x6587;&#x4EF6;&#x3001;sst&#x6587;&#x4EF6;&#x3001;&#x6E05;&#x5355;&#x6587;&#x4EF6;&#xFF0C;&#x672B;&#x5C3E;&#x90FD;&#x5E26;&#x7740;&#x5E8F;&#x5217;&#x53F7;&#xFF0C;&#x5176;&#x5E8F;&#x53F7;&#x90FD;&#x662F;&#x5355;&#x8C03;&#x9012;&#x589E;&#x7684;&#xFF08;&#x968F;&#x7740;<code>next_file_number</code>&#x4ECE;1&#x5F00;&#x59CB;&#x9012;&#x589E;&#xFF09;&#xFF0C;&#x4EE5;&#x4FDD;&#x8BC1;&#x4E0D;&#x548C;&#x4E4B;&#x524D;&#x7684;&#x6587;&#x4EF6;&#x540D;&#x91CD;&#x590D;&#x3002;</p>
<p><strong>5/log&#xFF1A;&#x7CFB;&#x7EDF;&#x7684;&#x8FD0;&#x884C;&#x65E5;&#x5FD7;&#xFF0C;&#x8BB0;&#x5F55;&#x7CFB;&#x7EDF;&#x7684;&#x8FD0;&#x884C;&#x4FE1;&#x606F;&#x6216;&#x8005;&#x9519;&#x8BEF;&#x65E5;&#x5FD7;&#x3002;</strong>
<strong>6/dbtmp&#xFF1A;&#x4E34;&#x65F6;&#x6570;&#x636E;&#x5E93;&#x6587;&#x4EF6;&#xFF0C;repair&#x65F6;&#x4E34;&#x65F6;&#x751F;&#x6210;&#x7684;&#x3002;</strong>
&#x8FD9;&#x91CC;&#x5C31;&#x6D89;&#x53CA;&#x5230;&#x51E0;&#x4E2A;&#x5173;&#x952E;&#x7684;number&#x8BA1;&#x6570;&#x5668;&#xFF0C;log&#x6587;&#x4EF6;&#x7F16;&#x53F7;&#xFF0C;&#x4E0B;&#x4E00;&#x4E2A;&#x6587;&#x4EF6;&#xFF08;sstable&#x3001;log&#x548C;manifest&#xFF09;&#x7F16;&#x53F7;&#xFF0C;sequence&#x3002;
&#x6240;&#x6709;&#x6B63;&#x5728;&#x4F7F;&#x7528;&#x7684;&#x6587;&#x4EF6;&#x7F16;&#x53F7;&#xFF0C;&#x5305;&#x62EC;log&#x3001;sstable&#x548C;manifest&#x90FD;&#x5E94;&#x8BE5;&#x5C0F;&#x4E8E;&#x4E0B;&#x4E00;&#x4E2A;&#x6587;&#x4EF6;&#x7F16;&#x53F7;&#x8BA1;&#x6570;&#x5668;&#x3002;
<strong>9.1.2 Level 0</strong></p>
<p>&#x5F53;&#x64CD;&#x4F5C;log&#x8D85;&#x8FC7;&#x4E00;&#x5B9A;&#x5927;&#x5C0F;&#x65F6;&#xFF08;&#x7F3A;&#x7701;&#x662F;1MB&#xFF09;&#xFF0C;&#x6267;&#x884C;&#x5982;&#x4E0B;&#x64CD;&#x4F5C;&#xFF1A;</p>
<blockquote>
<p>S1 &#x521B;&#x5EFA;&#x65B0;&#x7684;memtable&#x548C;log&#x6587;&#x4EF6;&#xFF0C;&#x5E76;&#x91CD;&#x5BFC;&#x5411;&#x65B0;&#x7684;&#x66F4;&#x65B0;&#x5230;&#x65B0;memtable&#x548C;log&#x4E2D;&#xFF1B;
S2 &#x5728;&#x540E;&#x53F0;&#xFF1A;
S2.1 &#x5C06;&#x524D;&#x4E00;&#x4E2A;memtable&#x7684;&#x5185;&#x5BB9;dump&#x5230;sstable&#x6587;&#x4EF6;&#xFF1B;
S2.2 &#x4E22;&#x5F03;&#x524D;&#x4E00;&#x4E2A;memtable&#xFF1B;
S2.3 &#x5220;&#x9664;&#x65E7;&#x7684;log&#x6587;&#x4EF6;&#x548C;memtable
S2.4 &#x628A;&#x521B;&#x5EFA;&#x7684;sstable&#x6587;&#x4EF6;&#x653E;&#x5230;level 0</p>
</blockquote>
<h3 id="92-compaction"><a name="92-compaction" class="anchor-navigation-ex-anchor" href="#92-compaction"><i class="fa fa-link" aria-hidden="true"></i></a>9.2 Compaction</h3>
<p>&#x5F53;<code>level L</code>&#x7684;&#x603B;&#x6587;&#x4EF6;&#x5927;&#x5C0F;&#x67E5;&#x8FC7;&#x9650;&#x5236;&#x65F6;&#xFF0C;&#x6211;&#x4EEC;&#x5C31;&#x5728;&#x540E;&#x53F0;&#x6267;&#x884C;<strong>compaction&#x64CD;&#x4F5C;</strong>&#x3002;Compaction&#x64CD;&#x4F5C;&#x4ECE;level L&#x4E2D;&#x9009;&#x62E9;&#x4E00;&#x4E2A;&#x6587;&#x4EF6;f&#xFF0C;&#x4EE5;&#x53CA;&#x9009;&#x62E9;&#x4E2D;&#x6240;&#x6709;&#x548C;f&#x6709;&#x91CD;&#x53E0;&#x7684;&#x6587;&#x4EF6;&#x3002;&#x5982;&#x679C;&#x67D0;&#x4E2A;level (L+1)&#x7684;&#x6587;&#x4EF6;ff&#x53EA;&#x662F;&#x548C;f&#x90E8;&#x5206;&#x91CD;&#x5408;&#xFF0C;compaction&#x4F9D;&#x7136;&#x9009;&#x62E9;ff&#x7684;&#x5B8C;&#x6574;&#x5185;&#x5BB9;&#x4F5C;&#x4E3A;&#x8F93;&#x5165;&#xFF0C;&#x5728;compaction&#x540E;f&#x548C;ff&#x90FD;&#x4F1A;&#x88AB;&#x4E22;&#x5F03;&#x3002;
&#x53E6;&#x5916;&#xFF1A;&#x56E0;&#x4E3A;<code>level 0</code>&#x6709;&#x4E9B;&#x7279;&#x6B8A;&#xFF08;&#x540C;&#x5C42;&#x6587;&#x4EF6;&#x53EF;&#x80FD;&#x6709;&#x91CD;&#x5408;&#xFF09;&#xFF0C;&#x4ECE;level 0&#x5230;level 1&#x7684;<code>compaction</code>&#x5C31;&#x9700;&#x8981;&#x7279;&#x6B8A;&#x5BF9;&#x5F85;&#xFF1A;level 0&#x7684;compaction&#x53EF;&#x80FD;&#x4F1A;&#x9009;&#x62E9;&#x591A;&#x4E2A;level 0&#x6587;&#x4EF6;&#xFF0C;&#x5982;&#x679C;&#x5B83;&#x4EEC;&#x4E4B;&#x95F4;&#x6709;&#x91CD;&#x53E0;&#x3002;
Compaction&#x5C06;&#x9009;&#x62E9;&#x7684;&#x6587;&#x4EF6;&#x5185;&#x5BB9;<code>merge</code>&#x8D77;&#x6765;&#xFF0C;&#x5E76;&#x751F;&#x6210;&#x5230;&#x4E00;&#x7CFB;&#x5217;&#x7684;level (L+1)&#x6587;&#x4EF6;&#x4E2D;&#xFF0C;&#x5982;&#x679C;&#x8F93;&#x51FA;&#x6587;&#x4EF6;&#x8D85;&#x8FC7;&#x8BBE;&#x7F6E;&#xFF08;2MB&#xFF09;&#xFF0C;&#x5C31;&#x5207;&#x6362;&#x5230;&#x65B0;&#x7684;&#x3002;&#x5F53;&#x8F93;&#x51FA;&#x6587;&#x4EF6;&#x7684;key&#x8303;&#x56F4;&#x592A;&#x5927;&#x4EE5;&#x81F3;&#x4E8E;&#x548C;&#x8D85;&#x8FC7;10&#x4E2A;level (L+2)&#x6587;&#x4EF6;&#x6709;&#x91CD;&#x5408;&#x65F6;&#xFF0C;&#x4E5F;&#x4F1A;&#x5207;&#x6362;&#x3002;&#x540E;&#x4E00;&#x4E2A;&#x89C4;&#x5219;&#x786E;&#x4FDD;&#x4E86;level (L+1)&#x7684;&#x6587;&#x4EF6;&#x4E0D;&#x4F1A;&#x548C;&#x8FC7;&#x591A;&#x7684;level (L+2)&#x6587;&#x4EF6;&#x6709;&#x91CD;&#x5408;&#xFF0C;&#x5176;&#x540E;&#x7684;level (L+1) compaction&#x4E0D;&#x4F1A;&#x9009;&#x62E9;&#x8FC7;&#x591A;&#x7684;level (L+2)&#x6587;&#x4EF6;&#x3002;
&#x8001;&#x7684;&#x6587;&#x4EF6;&#x4F1A;&#x88AB;&#x4E22;&#x5F03;&#xFF0C;&#x65B0;&#x521B;&#x5EFA;&#x7684;&#x6587;&#x4EF6;&#x5C06;&#x52A0;&#x5165;&#x5230;server&#x72B6;&#x6001;&#x4E2D;&#x3002;
Compaction&#x64CD;&#x4F5C;&#x5728;key&#x7A7A;&#x95F4;&#x4E2D;&#x5FAA;&#x73AF;&#x6267;&#x884C;&#xFF0C;&#x8BE6;&#x7EC6;&#x8BB2;&#x4E00;&#x70B9;&#x5C31;&#x662F;&#xFF0C;&#x5BF9;&#x4E8E;&#x6BCF;&#x4E2A;level&#xFF0C;&#x6211;&#x4EEC;&#x8BB0;&#x5F55;&#x4E0A;&#x6B21;compaction&#x7684;<code>ending key</code>&#x3002;Level&#x7684;&#x4E0B;&#x4E00;&#x6B21;compaction&#x5C06;&#x9009;&#x62E9;ending key&#x4E4B;&#x540E;&#x7684;&#x7B2C;&#x4E00;&#x4E2A;&#x6587;&#x4EF6;&#xFF08;&#x5982;&#x679C;&#x8FD9;&#x6837;&#x7684;&#x6587;&#x4EF6;&#x4E0D;&#x5B58;&#x5728;&#xFF0C;&#x5C06;&#x4F1A;&#x8DF3;&#x5230;key&#x7A7A;&#x95F4;&#x7684;&#x5F00;&#x59CB;&#xFF09;&#x3002;
Compaction&#x4F1A;&#x5FFD;&#x7565;&#x88AB;&#x5199;&#x8986;&#x76D6;&#x7684;&#x503C;&#xFF0C;&#x5982;&#x679C;&#x66F4;&#x9AD8;&#x4E00;&#x5C42;&#x7684;level&#x6CA1;&#x6709;&#x6587;&#x4EF6;&#x7684;&#x8303;&#x56F4;&#x5305;&#x542B;&#x4E86;&#x8FD9;&#x4E2A;key&#xFF0C;key&#x7684;&#x5220;&#x9664;&#x6807;&#x8BB0;&#x4E5F;&#x4F1A;&#x88AB;&#x5FFD;&#x7565;&#x3002;</p>
<p><strong>9.2.1 &#x65F6;&#x95F4;</strong></p>
<p>Level 0&#x7684;compaction&#x6700;&#x591A;&#x4ECE;level 0&#x8BFB;&#x53D6;4&#x4E2A;1MB&#x7684;&#x6587;&#x4EF6;&#xFF0C;&#x4EE5;&#x53CA;&#x6240;&#x6709;&#x7684;level 1&#x6587;&#x4EF6;&#xFF08;10MB&#xFF09;&#xFF0C;&#x4E5F;&#x5C31;&#x662F;&#x6211;&#x4EEC;&#x5C06;&#x8BFB;&#x53D6;14MB&#xFF0C;&#x5E76;&#x5199;&#x5165;14BM&#x3002;
Level &gt; 0&#x7684;compaction&#xFF0C;&#x4ECE;level L&#x9009;&#x62E9;&#x4E00;&#x4E2A;2MB&#x7684;&#x6587;&#x4EF6;&#xFF0C;&#x6700;&#x574F;&#x60C5;&#x51B5;&#x4E0B;&#xFF0C;&#x5C06;&#x4F1A;&#x548C;levelL+1&#x7684;12&#x4E2A;&#x6587;&#x4EF6;&#x6709;&#x91CD;&#x5408;&#xFF08;10&#xFF1A;level L+1&#x7684;&#x603B;&#x6587;&#x4EF6;&#x5927;&#x5C0F;&#x662F;level L&#x7684;10&#x500D;&#xFF1B;&#x8FB9;&#x754C;&#x7684;2&#xFF1A;level L&#x7684;&#x6587;&#x4EF6;&#x8303;&#x56F4;&#x901A;&#x5E38;&#x4E0D;&#x4F1A;&#x548C;level L+1&#x7684;&#x6587;&#x4EF6;&#x5BF9;&#x9F50;&#xFF09;&#x3002;&#x56E0;&#x6B64;Compaction&#x5C06;&#x4F1A;&#x8BFB;26MB&#xFF0C;&#x5199;26MB&#x3002;&#x5BF9;&#x4E8E;100MB/s&#x7684;&#x78C1;&#x76D8;IO&#x6765;&#x8BB2;&#xFF0C;compaction&#x5C06;&#x6700;&#x574F;&#x9700;&#x8981;0.5&#x79D2;&#x3002;
&#x5982;&#x679C;&#x78C1;&#x76D8;IO&#x66F4;&#x4F4E;&#xFF0C;&#x6BD4;&#x5982;10MB/s&#xFF0C;&#x90A3;&#x4E48;compaction&#x5C31;&#x9700;&#x8981;&#x66F4;&#x957F;&#x7684;&#x65F6;&#x95F4;5&#x79D2;&#x3002;&#x5982;&#x679C;user&#x4EE5;10MB/s&#x7684;&#x901F;&#x5EA6;&#x5199;&#x5165;&#xFF0C;&#x6211;&#x4EEC;&#x53EF;&#x80FD;&#x751F;&#x6210;&#x5F88;&#x591A;level 0&#x6587;&#x4EF6;&#xFF08;50&#x4E2A;&#x6765;&#x88C5;&#x8F7D;5*10MB&#x7684;&#x6570;&#x636E;&#xFF09;&#x3002;&#x8FD9;&#x5C06;&#x4F1A;&#x4E25;&#x91CD;&#x5F71;&#x54CD;&#x8BFB;&#x53D6;&#x6548;&#x7387;&#xFF0C;&#x56E0;&#x4E3A;&#x9700;&#x8981;merge&#x66F4;&#x591A;&#x7684;&#x6587;&#x4EF6;&#x3002;</p>
<blockquote>
<p>&#x89E3;&#x51B3;&#x65B9;&#x6CD5;1&#xFF1A;&#x4E3A;&#x4E86;&#x964D;&#x4F4E;&#x8BE5;&#x95EE;&#x9898;&#xFF0C;&#x6211;&#x4EEC;&#x53EF;&#x80FD;&#x60F3;&#x589E;&#x52A0;log&#x5207;&#x6362;&#x7684;&#x9608;&#x503C;&#xFF0C;&#x7F3A;&#x70B9;&#x5C31;&#x662F;&#xFF0C;log&#x6587;&#x4EF6;&#x8D8A;&#x5927;&#xFF0C;&#x5BF9;&#x5E94;&#x7684;memtable&#x6587;&#x4EF6;&#x5C31;&#x8D8A;&#x5927;&#xFF0C;&#x8FD9;&#x9700;&#x8981;&#x66F4;&#x591A;&#x7684;&#x5185;&#x5B58;&#x3002;
&#x89E3;&#x51B3;&#x65B9;&#x6CD5;2&#xFF1A;&#x5F53;level 0&#x6587;&#x4EF6;&#x592A;&#x591A;&#x65F6;&#xFF0C;&#x4EBA;&#x5DE5;&#x964D;&#x4F4E;&#x5199;&#x5165;&#x901F;&#x5EA6;&#x3002;
&#x89E3;&#x51B3;&#x65B9;&#x6CD5;3&#xFF1A;&#x964D;&#x4F4E;merge&#x7684;&#x5F00;&#x9500;&#xFF0C;&#x5982;&#x628A;level 0&#x6587;&#x4EF6;&#x90FD;&#x65E0;&#x538B;&#x7F29;&#x7684;&#x5B58;&#x653E;&#x5728;cache&#x4E2D;&#x3002;</p>
</blockquote>
<p><strong>9.2.2 &#x6587;&#x4EF6;&#x6570;</strong></p>
<p>&#x5BF9;&#x4E8E;&#x66F4;&#x9AD8;&#x7684;<code>level</code>&#x6211;&#x4EEC;&#x53EF;&#x4EE5;&#x521B;&#x5EFA;&#x66F4;&#x5927;&#x7684;&#x6587;&#x4EF6;&#xFF0C;&#x800C;&#x4E0D;&#x662F;2MB&#xFF0C;&#x4EE3;&#x4EF7;&#x5C31;&#x662F;&#x66F4;&#x591A;&#x7A81;&#x53D1;&#x6027;&#x7684;<code>compaction</code>&#x3002;&#x6216;&#x8005;&#xFF0C;&#x6211;&#x4EEC;&#x53EF;&#x4EE5;&#x8003;&#x8651;&#x5206;&#x533A;&#xFF0C;&#x628A;&#x6587;&#x4EF6;&#x653E;&#x5B58;&#x653E;&#x591A;&#x76EE;&#x5F55;&#x4E2D;&#x3002;
&#x5728;2011&#x5E74;2&#x6708;4&#x53F7;&#xFF0C;&#x4F5C;&#x8005;&#x505A;&#x4E86;&#x4E00;&#x4E2A;&#x5B9E;&#x9A8C;&#xFF0C;&#x5728;ext3&#x6587;&#x4EF6;&#x7CFB;&#x7EDF;&#x4E2D;&#x6253;&#x5F00;100KB&#x7684;&#x6587;&#x4EF6;&#xFF0C;&#x7ED3;&#x679C;&#x8868;&#x660E;&#x53EF;&#x4EE5;&#x4E0D;&#x9700;&#x8981;&#x5206;&#x533A;&#x3002;</p>
<blockquote>
<p>&#x6587;&#x4EF6;&#x6570;    &#x6587;&#x4EF6;&#x6253;&#x5F00;ms
1000      9
10000    10
100000   16</p>
</blockquote>
<h3 id="93-recovery--gc"><a name="93-recovery--gc" class="anchor-navigation-ex-anchor" href="#93-recovery--gc"><i class="fa fa-link" aria-hidden="true"></i></a>9.3 Recovery &amp; GC</h3>
<p><strong>9.3.1 Recovery</strong></p>
<p>Db&#x6062;&#x590D;&#x7684;&#x6B65;&#x9AA4;&#xFF1A;</p>
<blockquote>
<p>S1 &#x9996;&#x5148;&#x4ECE;CURRENT&#x8BFB;&#x53D6;&#x6700;&#x540E;&#x63D0;&#x4EA4;&#x7684;MANIFEST
S2 &#x8BFB;&#x53D6;MANIFEST&#x5185;&#x5BB9;
S3 &#x6E05;&#x9664;&#x8FC7;&#x671F;&#x6587;&#x4EF6;
S4 &#x8FD9;&#x91CC;&#x53EF;&#x4EE5;&#x6253;&#x5F00;&#x6240;&#x6709;&#x7684;sstable&#x6587;&#x4EF6;&#xFF0C;&#x4F46;&#x662F;&#x66F4;&#x597D;&#x7684;&#x65B9;&#x6848;&#x662F;lazy open
S5 &#x628A;log&#x8F6C;&#x6362;&#x4E3A;&#x65B0;&#x7684;level 0sstable
S6 &#x5C06;&#x65B0;&#x5199;&#x64CD;&#x4F5C;&#x5BFC;&#x5411;&#x5230;&#x65B0;&#x7684;log&#x6587;&#x4EF6;&#xFF0C;&#x4ECE;&#x6062;&#x590D;&#x7684;&#x5E8F;&#x53F7;&#x5F00;&#x59CB;
9.3.2 GC</p>
</blockquote>
<p>&#x5783;&#x573E;&#x56DE;&#x6536;&#xFF0C;&#x6BCF;&#x6B21;compaction&#x548C;recovery&#x4E4B;&#x540E;&#x90FD;&#x4F1A;&#x6709;&#x6587;&#x4EF6;&#x88AB;&#x5E9F;&#x5F03;&#xFF0C;&#x6210;&#x4E3A;&#x5783;&#x573E;&#x6587;&#x4EF6;&#x3002;<code>GC</code>&#x5C31;&#x662F;&#x5220;&#x9664;&#x8FD9;&#x4E9B;&#x6587;&#x4EF6;&#x7684;&#xFF0C;&#x5B83;&#x5728;&#x6BCF;&#x6B21;compaction&#x548C;recovery&#x5B8C;&#x6210;&#x4E4B;&#x540E;&#x88AB;&#x8C03;&#x7528;&#x3002;</p>
<footer class="page-footer"><span class="copyright">&#x5982;&#x9700;&#x4E0B;&#x8F7D;&#x672C;&#x7AD9;&#x5168;&#x90E8;&#x6280;&#x672F;&#x6587;&#x7AE0;&#xFF0C;&#x53EF;&#x4EE5;&#x5728;&#x3010;&#x9AD8;&#x6027;&#x80FD;&#x670D;&#x52A1;&#x5668;&#x5F00;&#x53D1;&#x3011;&#x516C;&#x4F17;&#x53F7;&#x56DE;&#x590D;&#x5173;&#x952E;&#x5B57;&#x201C;&#x6587;&#x7AE0;&#x4E0B;&#x8F7D;&#x201D;&#x5373;&#x53EF;&#x3002;</span><span class="footer-modification">&#x6700;&#x8FD1;&#x66F4;&#x65B0;&#x65F6;&#x95F4;&#xFF1A;
2020-10-03 13:25:38
</span></footer>
<script>console.log("plugin-popup....");document.onclick = function(e){ e.target.tagName === "IMG" && window.open(e.target.src,e.target.src)}</script><style>img{cursor:pointer}</style>
						
					</section>
					
    </div>
    <div class="search-results">
        <div class="has-results">
            
            <h1 class="search-results-title"><span class='search-results-count'></span> results matching "<span class='search-query'></span>"</h1>
            <ul class="search-results-list"></ul>
            
        </div>
        <div class="no-results">
            
            <h1 class="search-results-title">No results matching "<span class='search-query'></span>"</h1>
            
        </div>
    </div>
</div>

				</div>
			</div>
			
		</div>

		
		
		<a href="leveldb源码分析13.html" class="navigation navigation-prev " aria-label="Previous page: leveldb源码分析13">
			<i class="fa fa-angle-left"></i>
		</a>
		
		
		<a href="leveldb源码分析15.html" class="navigation navigation-next " aria-label="Next page: leveldb源码分析15">
			<i class="fa fa-angle-right"></i>
		</a>
		
		
		
	</div>
	<script>
		var gitbook = gitbook || [];
		gitbook.push(function() {
			gitbook.page.hasChanged({"page":{"title":"leveldb源码分析14","level":"7.2.14","depth":2,"next":{"title":"leveldb源码分析15","level":"7.2.15","depth":2,"path":"articles/leveldb源码分析/leveldb源码分析15.md","ref":"articles/leveldb源码分析/leveldb源码分析15.md","articles":[]},"previous":{"title":"leveldb源码分析13","level":"7.2.13","depth":2,"path":"articles/leveldb源码分析/leveldb源码分析13.md","ref":"articles/leveldb源码分析/leveldb源码分析13.md","articles":[]},"dir":"ltr"},"config":{"plugins":["chapter-fold","-lunr","-search","search-pro","splitter","popup","back-to-top-button","hide-element","prism","-highlight","tbfed-pagefooter","code","anchor-navigation-ex","theme-fexa","livereload"],"styles":{"website":"styles/website.css","pdf":"styles/pdf.css","epub":"styles/epub.css","mobi":"styles/mobi.css","ebook":"styles/ebook.css","print":"styles/print.css"},"pluginsConfig":{"tbfed-pagefooter":{"copyright":"如需下载本站全部技术文章，可以在【高性能服务器开发】公众号回复关键字“文章下载”即可。","modify_label":"最近更新时间：","modify_format":"YYYY-MM-DD HH:mm:ss"},"chapter-fold":{},"prism":{},"livereload":{},"splitter":{},"search-pro":{},"popup":{},"theme-fexa":{"search-placeholder":"输入关键字搜索","logo":"./logo.png","favicon":"./favicon.ico"},"code":{"copyButtons":true},"hide-element":{"elements":[".gitbook-link"]},"fontsettings":{"theme":"white","family":"sans","size":2},"anchor-navigation-ex":{"showLevel":false,"associatedWithSummary":true,"mode":"float","showGoTop":false,"printLog":false,"multipleH1":true,"float":{"floatIcon":"fa fa-navicon","showLevelIcon":false,"level1Icon":"","level2Icon":"","level3Icon":""},"pageTop":{"showLevelIcon":false,"level1Icon":"","level2Icon":"","level3Icon":""}},"back-to-top-button":{},"sharing":{"facebook":true,"twitter":true,"google":false,"weibo":false,"instapaper":false,"vk":false,"all":["facebook","google","twitter","weibo","instapaper"]},"theme-default":{"styles":{"website":"styles/website.css","pdf":"styles/pdf.css","epub":"styles/epub.css","mobi":"styles/mobi.css","ebook":"styles/ebook.css","print":"styles/print.css"},"showLevel":false}},"theme":"default","author":"easy_coder","pdf":{"pageBreaksBefore":"/","headerTemplate":null,"paperSize":"a4","margin":{"right":62,"left":62,"top":36,"bottom":36},"fontSize":12,"fontFamily":"Arial","footerTemplate":null,"chapterMark":"pagebreak","pageNumbers":false},"structure":{"langs":"LANGS.md","readme":"README.md","glossary":"GLOSSARY.md","summary":"SUMMARY.md"},"isbn":"","variables":{},"title":"高性能服务器开发 技术专栏","links":{},"gitbook":"*","description":"","theme-default":{"showLevel":true},"extension":null},"file":{"path":"articles/leveldb源码分析/leveldb源码分析14.md","mtime":"2020-10-03T05:25:38.483Z","type":"markdown"},"gitbook":{"version":"3.2.3","time":"2020-10-09T15:31:57.905Z"},"basePath":"../..","book":{"language":""}});
		});
	</script>
</div>

        
    <script src="../../gitbook/gitbook.js"></script>
    <script src="../../gitbook/theme.js"></script>
    
        
        <script src="../../gitbook/gitbook-plugin-chapter-fold/chapter-fold.js"></script>
        
    
        
        <script src="../../gitbook/gitbook-plugin-search-pro/jquery.mark.min.js"></script>
        
    
        
        <script src="../../gitbook/gitbook-plugin-search-pro/search.js"></script>
        
    
        
        <script src="../../gitbook/gitbook-plugin-splitter/splitter.js"></script>
        
    
        
        <script src="../../gitbook/gitbook-plugin-back-to-top-button/plugin.js"></script>
        
    
        
        <script src="../../gitbook/gitbook-plugin-hide-element/plugin.js"></script>
        
    
        
        <script src="../../gitbook/gitbook-plugin-code/plugin.js"></script>
        
    
        
        <script src="../../gitbook/gitbook-plugin-livereload/plugin.js"></script>
        
    
        
        <script src="../../gitbook/gitbook-plugin-sharing/buttons.js"></script>
        
    
        
        <script src="../../gitbook/gitbook-plugin-fontsettings/fontsettings.js"></script>
        
    
        
        <script src="../../gitbook/gitbook-plugin-theme-fexa/fexa.js"></script>
        
    

    </body>
</html>

